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(54) Method and apparatus for controlling software access to system resources 



(57) Methods, systems, and software for installing 
and operating selected software applications on a client 
computer that ts in communication with a server compu- 
ter on a computer network are described. In one aspect 
of the present invention, a method for controlling the 
degree of access to operating system resources for a 
software program running on a computer that is running 
said operating system is provided. The degree of 
access to the operating system resources is defined for 
the software program, and at least one file including 
instructions for executing the software program is 
loaded on the computer from the server computer. The 
file is examined to determine the degree of system-level 
access available to the software program when the soft- 
ware program is being executed by the computer. The 
software program is executed, and a program instruc- 
tion associated with the software program is intercepted 
when the software is being executed on the computer. A 
determination is then made to determine if the program 
instruction includes an operation that is outside of a 
degree of system-level access that is available to the 
software program, and if it is determined that the soft- 
ware program has permission to access system-level 
resources associated with the computer that are within 
the degree of system-level access available to the soft- 
ware, the program instruction is executed. 
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Description 

BACKGROUND OF THE INVENTION 

1 . Field of Invention 

The present invention relates generally to methods 
and apparatus tor controlling the access to computer 
resources by software running on a computer. More 
specifically, the present invention relates to methods 
and apparatus for controlling the access to system 
resources on a client computer by software downloaded 
to the client computer from a server computer. 

2. Background 

Prior to the rise of the personal computer, computer 
users were limited to operating software that ran on 
large, mainframe computers using terminals that typi- 
cally included a keyboard for entering data and com- 
mands and a video display device (or printer) for 
viewing output Although mainframes provided very 
powerful computing platforms, they suffered from seri- 
ous drawbacks. In particular, mainframes were expen- 
sive to install and operate and they required all users to 
be connected directly to the mainframe through a termi- 
nal, which limited access to the mainframe for many 
people. In addition, users had very limited control over 
their computing environments, usually having to adapt 
their work styles and problems to suit the software and 
administration of the mainframe computer. 

Beginning in the late 1970s personal computers 
began to overtake mainframes as the dominant comput- 
ing platform tor both personal, business, and scientific 
uses. For single users, personal computers often could 
provide the same computing speed as the older main* 
frames that had to accommodate many processing jobs 
simultaneously. In addition, software that ran on the per- 
sonal computers became more "user-friendly." thereby 
allowing computer users to adapt both the computer 
and the software to suit their particular computation 
needs. The release from requiring a connection from a 
terminal to a mainframe allowed personal computers to 
be located just about anywhere within an organization 
or at home. This capability further assured the domi- 
nance of the personal computer over the mainframe as 
computing power could be located at sites where it was 
needed. No longer did users have to tailor their opera- 
tions around large, expensive, finicky mainframe com- 
puting centers. 

As the computing power and data storage capaci- 
ties of personal computers exploded throughout the 
1980s, the dominance of the personal computer 
seemed to be assured. As the 1980s drew to a close, 
however, a new phenomenon began to emerge which 
appears likely to overtake the personal computer revo- 
lution of the past two decades. Today, ever increasing 
numbers of personal computers are linked to each other 



through high speed data networks. The most popular 
network currently is the "Internet, " which is the network 
comprising various business, academic, and personal 
computer sites across the globe. The popularity of the 
5 Internet, and, more particularly, that aspect of the Inter- 
net referred to as the "World Wide Web." has prompted 
many organizations to form internal computer networks, 
which are often referred to as "intranets." This interest in 
network computing has been sparked by a combination 
70 of high speed data networks and increasingly sophisti- 
cated network servers, routers and other devices which 
allow many independent personal computers to com- 
municate efficiently. 

The attractiveness of the World Wide Web stems in 
is part from its highly visual character, the same factor that 
played a large role in the rise of the personal computer 
and its dominance over the mainframe. Typically, the 
World Wide Web is organized into various "web sites" 
which typically comprise a server that transmits data to 
20 a client computer running a "browser." The browser is 
software that provides a user with a window and various 
controls through which data from the server can be 
viewed and navigated. A particularly useful feature of 
World Wide Web data is its ability to be linked through 
25 hypertext commands such that users can quickly navi- 
gate from one document to another and even from one 
web site to another through very simple intuitive com- 
mands such as the activation of a mouse button. Using 
the World Wide Web, users can view and/or download 
so text, graphics and hear sounds from sites all over the 
globe. In addition users can also download new soft- 
ware, or software capable of modifying programs 
already installed on the client computers. 

These same features available to users of the 
35 World Wide Web on the Internet can also be provided to 
users of a local network through an "intranet", a non- 
public computer network that includes clients and serv- 
ers arranged analogously to the Internet. This capability 
has received increasing attention from many organiza- 
40 tons as information useful to employees carrying out 
their assignments can be distributed quickly throughout 
the network to personal computers within the organiza- 
tion. In particular, many organizations are utilizing 
intranets to provide access to databases and custom 
45 software programs for individuals in the organization 
using such intranets. For example custom software 
applets created using the Java™ programming lan- 
guage (available commercially from Sun Microsystems 
of Palo Alto. California), can be operated in conjunction 
so with software and data already installed on the remote 
computer which is either external or internal to the 
intranet to provide users access to data and software 
specific to their job tasks without the difficulties associ- 
ated with disseminating and maintaining many copies of 
55 special-purpose software as has been done tradition- 
ally. 

It is often desirable for software distributed through 
a secure intranet to have full access to the system 
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resources of the client computer; whereas software dis- 
tributed over less secure networks external to the 
' intranet system generally are allowed little or no access 
to system resources, such as file moving capabilities, as 
such software cannot always be trusted. For example, 5 
some software applications include functions that install 
computer viruses on the host computer. Other software 
application may copy, alter, or delete critical data from 
the host computer and even forward that data to another 
computer system surreptitiously. Unfortunately, there rs ;o 
no viable method or apparatus to enable trusted soft- 
ware to access certain resources while restricting other 
software from accessing the same resource. Users are 
therefore left with a trade-off between enabling all soft- 
ware (trusted or suspect) access all system resources 15 
or limiting the access of all software in an effort to pre- 
serve the security of the client system 

Thus, it would be of great benefit to computer users, 
and especially computer users within organizations in 
which multiple computer users are connected through a 20 
corrputer network, to provide methods and systems for 
controlling resource access for both information and 
software over the network so that the above-described 
problems associated with highly decentralized compu- 
ter networks can be mitigated. As will be described here 25 
and below, the present invention meets these and other 
needs. 

SUMMARY OF THE INVENTION 

30 

The present invention addresses the above- 
described difficulties in managing software distribution 
across networked computers by providing, in one 
aspect, a method, system, and software for controlling 
the access to server resources by selected software ss 
applications on a first computer acting as a client com- 
puter that is in communication with a second computer 
acting as a server computer on a computer network. 

In one aspect of the present invention, a method for 
controlling the degree of access to operating system <o 
resources for a software program running on a compu- 
ter. The degree of access to the operating system 
resources is defined for the software program, and at 
least one file including instructions for executing the 
software program is loaded on the computer. The file is 45 
examined to determine the degree of system-level 
access available to the software program when the soft- 
ware program is being executed by the computer. The 
software program is executed, and a program instruc- 
tion requesting access to secure resources associated so 
with the software program is intercepted when the soft- 
ware is being executed on the computer. A determina- 
tion is then made to determine if the program instruction 
includes an operation that is outside of a degree of sys- 
tem-level access that is available to the software pro- ss 
gram, and if it is determined that the software program 
has permission to access system-level resources asso- 
ciated with the computer that are within the degree of 



system-level access available to the software, the pro- 
gram instruction is executed. 

In another aspect of the present invention, a 
method for controlling the degree of access to system 
resources for a software program running on a client 
computer that is running the operating system, where at 
least some of the operating system resources reside on 
a server computer that is coupled with the client compu- 
ter, is provided. The degree of access to the operating 
system resources tor the software program is defined, 
and at least one file including instructions for executing 
the software program on the client computer is loaded. 
The file is examined to determine the degree of system- 
level access available to the software program when the 
software program is being executed by the client com- 
puter. The software program is executed on the client 
computer, and a program instruction associated with the 
software program is intercepted when the software pro- 
gram is being executed on the client computer. A deter- 
mination is made regarding whether the program 
instruction includes an operation that is outside the 
degree of system-level access available to the software 
program, and when it is determined that the software 
program has permission to access system-level 
resources that are within the degree of system-level 
access available to the software program, the program 
instruction is executed. These, and other aspects and 
advantages of the present invention, will become appar- 
ent when the Description below is read in conjunction 
with the accompanying Drawings. 

BRIEF DESCRIPTION OF THE DRAWINGS 

The invention, together with further advantages 
thereof, may best be understood by reference to the fol- 
lowing description taken in conjunction with the accom- 
panying drawings in which: 

Fig. 1a is a diagrammatic representation of a wide 
area computer network in which both users and 
intranets are coupled by a computer network 
through the Internet. 

Rg. 1b is a diagrammatic representation of a con- 
ventional intranet system. 
Fig. 2a is a diagrammatic representation of a collec- 
tion of class files in accordance with an embodi- 
ment of the present invention. 
Fig. 2b is a diagrammatic representation of an 
archive file data format in accordance with an 
embodiment of the present invention. 
Rg. 3a is a diagrammatic representation of a client- 
side directory structure in accordance with an 
embodiment of the present invention. 
Rg. 3b is a diagrammatic representation of the 
structure of a client-side configuration file in accord- 
ance with an embodiment of the present invention. 
Rg. 3c is a diagrammatic representation of the 
structure of a client-side access file in accordance 
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with an embodiment of the present invention. 
Fig. 3d is a diagrammatic representation of the 
" structure of a client-side group specification file in 
accordance with an embodiment of the present 
invention. 

Fig. 4 is a process flow diagram which illustrates a 
method of executing a request to access a resource 
in accordance with an embodiment of the present 
invention. 

Fig. 5 is a process flow diagram which illustrates the 
steps associated with validating class files in 
accordance with an embodiment of the present 
invention. 

Fig. 6 is a process flow diagram which illustrates the 
steps associated with executing an applet in 
accordance with an embodiment of the present 
invention. 

Fig. 7 is a process flow diagram which illustrates the 
steps associated with calling a security manager in 
accordance with an embodiment of the present 
invention. 

Fig. 8 is a diagrammatic representation of a compu- 
ter system in accordance with the present inven- 
tion. 

DETAILED DESCRIPTION OF THE DRAWINGS 

Certain embodiments of a method and apparatus 
for controlling the access by applets to system 
resources will be described below making reference to 
the accompanying drawings. 

An illustration of one network in accordance with 
the present invention is provided in Fig. 1a. Included in 
the network illustrated in Fig. 1a are intranets 102 and 
104 and an individual external computer shown at 106. 
The structure of intranets 102 and 104 is described in 
greater detail below with respect to Fig. 1b Both the 
intranets and the user are connected to the computer 
network through a variety of computer gateways 
("GMT). In some embodiments, the computer network 
includes the Internet. Referring to Fig. la more specifi- 
cally, intranet 102 is coupled with intranet 104 and user 
106 through the Internet which is shown generally at 
108. The connection between intranet 102 and the 
Internet 108 is provided first through a gateway 110 
which is coupled with intranet 102 and a "bactoone," or 
high capacity dataline 112. Data from a high capacity 
line 112 is routed through gateway 114 through the 
Internet 108 which data passes through a second gate- 
way 1 16 and into high capacity dataline shown at 1 18. 
As will be appreciated by those of skill in the computer 
network arts, dataline 1 18 can be the same as dataline 
112. or may represent a separate backbone to which 
various other individuals, or users, and networks are 
coupled. 

Data that travels from intranet 102 through the 
Internet 108 and over high speed dataline 1 18 passes 
through gateway 120 to intranet 104 or through gateway 



124 to user 106: Thus, according to the illustrated 
embodiment, data can be passed among user 106, 
intranet 104. and intranet 102. In particular, the data 
may travel through the Internet 108 as just described, or 

5 may pass across backbone 118 between user 106 and 
intranet 104. In some embodiments, intranet 104 and 
intranet 102 can be coupled directly through network 
configurations known to those of skill in the art as 
"extranets". Extranets are network arrangements in 

io which a given network or individual is coupled with a 
remote network through a dedicated data connection. 
This connection may include data that is routed through 
the Internet, as illustrated in Fig. 1a, or may be a direct 
data feed, such as through an ISDN or T-1 dataline. Var- 

T5 ious configurations in addition to methods and materials 
for establishing such configurations will be apparent to 
those of skill in the computer network and telecommuni- 
cations arts. 

One embodiment of an intranet, such as illustrated 

20 in Fig. 1a at 102 or 104, is provided in Fig. 1b at 50. A 
typical intranet 50 includes a server 60 which is coupled 
with clients 62 and 64. In addition, server 60 can be cou- 
pled to other client computers such as shown at 70, 72, 
and 74 through a router, hub or similar data transfer 

25 device such as shown at node 68. In addition, remote 
clients (not shown) can be connected to server 60 either 
through a direct line or through the use of telephone 
lines using, e.g. , a modem or similar device. In some 
cases, access to intranet 50 will be controlled to a high 

30 degree by a Yirewall" configuration which is illustrated 
by the box 75. The establishment of communications 
from users external to the firewall, such as remote client 
78, can be achieved by traversing a gateway which 
allows access to the protected server. Such a gateway 

35 is illustrated at 76. 

Typically, a server provides data and software that 
is accessible to the various clients which are in commu- 
nication with the server, either directly or through a 
device such as a router. The construction, maintenance, 

40 and operation of the server, router, and various client 
machines will be well known to those of skill in the art. 
In some particular embodiments, server 60 will be con- 
figured to provide data that is compatible with browser 
software such as that used to view data on the World 

45 Wide Web. Specifically, the data provided by server 60 
will be in the form of pages of data that can be examined 
using typical browser software. In one embotf ment the 
server and clients are configured to exchange not only 
data but computer software in the form of "applets," 

so such as those written in the Java™ programming lan- 
guage available from Sun Microsystems of Palo Alto, 
California. "Applets" as used herein are software pro- 
grams that are configured to be passed from a source 
computer, typically a server, to a client machine and run 

55 in conjunction with software already installed on the cli- 
ent. In one embodiment, the software with which the 
applet runs is the above-described browser software. 
Typically, applets provide additional functionalities to 
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browser software by performing various computational 
tasks which the browser software itself is not configured 
to^erform. Thus, users who download applets can pro- 
vide the browser software with additional functionalities 
that are not otherwise available to the browser software. 5 
Such additional capabilities can include, e.g., custom 
interfaces to a database. 

In general, a client, as for example client 62. calls 
into server 60 using a user agent, or a browser. User 
agents include, but are not limited to. HoUava™ , availa- to 
bte from Sun Microsystems, Incorporated of Palo Alto. 
California, and Netscape, available from Netscape 
Communications Corporation of Mountain View, Califor- 
nia, tn one embodiment the user agents generally 
includes a processing engine which executes the applet 
code, and a security manager used in the determination 
of whether an applet has access to certain system 
resources. Examples of such a security manager are 
provided herein below. 

According to one embodiment a server, located 
either on the Internet or within an intranet, provides 
class libraries which contain class files that define an 
applet. One example of such a class library is a Java™ 
class library. Specifically, a server can contain the class 
files that make up the applet, and the particular Web 
pages including HTML code that references the applet. 

According to one embodiment of the present inven- 
tion, applets are instantiated from class files that are 
downloaded from a source computer, or a server, to a 
client machine. The dass files may be grouped together 
into an archive file. Further, an archive file can be digit- 
ally signed, or otherwise marked, such that the origin of 
an applet created from the archive file can be reliably 
determined. The signature of an archive file can then be 
verified in order to determine which system resources 
are accessible to the machine on which the applet is 
executing. The use of signatures enables the access to 
system resources of the client machine by the applet to 
be controlled, e.g. . by reference to the security status of 
the server from where the applet originated. By way of 
example, an applet executing on one client may have 
different access privileges than the same applet execut- 
ing on a second client by virtue of the fact that the per- 
missions associated with the applet on each client may 
be different. This resource access control therefore ena- 
bles applets associated with secure machines, e.g., 
machines in the same intranet as the machine which 
contains the resources, to have more access to 
resources than applets associated with unsecure 
machines, e.g.. machines on the Internet. 

Fig. 2a is a diagrammatic representation of a collec- 
tion of class files in accordance with an embodiment of 
the present invention. The format of the collection of 
class data files, which is generally used on a server, is 
not arranged to accept signatures. That is. each class 
file typically defines a class residing on a server. The 
format is such that the collection includes any number of 
classes, as fa example class "1" 202, class "2" 204, 



and class "N" 206. A class may be defined as a software 
construct that defines data and methods, or sequences 
of statements that operate on the data, which are spe- 
cific to any applets that are subsequently constructed 
from that class. In other words, as previously stated, an 
applet may be constructed by instantiating a previously 
defined class. It should be appreciated that a single 
class may be used to construct many applets. 

The execution of an applet usually entails requests, 
or commands, to access system resources. While an 
applet may contain instructions to access many different 
system resources, due to security concerns, an applet 
is either allowed access to all of the specified system 
resources or access to none of the specified system 
resources under present design restraints. As dis- 
cussed above, this "all-or-nothing" approach to system 
resource access is often undesirable in that an applet 
running within an intranet system, for example, is 
"trusted," e.g.. of known origin, while an equivalent 
applet running externally to the intranet system is con- 
sidered to be unsecure. As the applet running within the 
intranet system and the equivalent applet running exter- 
nally are typically given the same access privileges to 
system resources, in order to maintain the security of 
the intranet system, the applets are generally given no 
access privileges. 

The ability to selectively control applets from 
accessing resources enables a user within an intranet 
system to restrict access to resources on an individual 
30 applet basis. Including a "signature," or an identifier, 
with class files that are used to instantiate an applet is 
one method which serves to enable an intranet organi- 
zation to selectively control applets. Signing, or mark- 
ing, class files such that it is possible to determine 
35 where the class files originated enables an intranet sys- 
tem to determine the appropriate access privileges 
associated with an applet instantiated from the class 
files. In addition, signing class files further enables a 
determination to be made regarding whether a class file 
40 has been tampered with. An archive file structure which 
permits a group of dass files to be digitally signed will 
be described below with respect to Fig. 2b. 

By providing an archive file which can be digitally 
signed, it becomes possible to enable an applet, either 
45 internal and external to an intranet system, that is con- 
structed from the class files associated with the archive 
file to access selected system resources within the 
intranet system. Checking the digital signature of the 
archive file makes it possWe to determine whether a 
so given applet has been tampered with, and which com- 
puters have signed the applet. As such, access privi- 
leges may be allocated based upon whether the applet 
originated from a secure, or trusted, host or from an 
unsecure host. In addition, in some embodiments, the 
55 allocation of access privileges enables users to decide 
which hosts are to be trusted and which are not to be 
trusted. 

Fig. 2b is a diagrammatic representation of an 
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archive file data format in accordance with an embodi- 350 is an example of a configuration file identified by 
ment of the present invention. In the described embodi- configuration file name 312 as mentioned above with 
ment, the archive format is a Java™ archive (JAR) respect to Fig. 3a. Configuration file 350 includes a 
format. Archive, or archive file, 210 includes a header table 352 which associates resources 354 on a server, 
signature 212 which is the signature that is typically 5 i.e., a server which the client wishes to access, with cor- 
used by a user agent to verify the validity of archive 210 responding access file names 356. That is, table 352 
and to determine the levels of access available to associates an entry in the resources "column" 354 with 
archive 210. In general, header signature 212 is a digital a corresponding entry in the access file names "col- 
signature which may be a part of a general header that umn" 356. Resources 354 are generally classifiers 
contains other information which information includes. w which identify various system resources, as for example 
but is not limited to. information corresponding to the files, hosts, and socket numbers. Access file names 356 
size of the archive. Archive 210 has any number of identify corresponding access files which contain secu- 
associated classes, as for example dass "1" 202, class rrty descriptors and other information that is relevant to 
"2" 204, and class "N" 206, from which applets and the control of access to system resources with which 
associated objects are instantiated. 15 access files are associated. The structure of an access 
Additionally, archive 210 may have associated data We wi " be described in more detail below with reference 
blocks, as for exanple data block 214. Data block 214 to Fig. 3c. It should be appreciated that due to the fact 
may contain images, text, or any arbitrary data that is that niore than one resource 354 may share the same 
considered to be a part of archive 210. In one embodi- security descriptor, access file names 356 and, there- 
ment, data block 214 may contain a text string that 20 fore, access files, may be associated with more than 
describes classes 202, 204. and 206 that are associ- one resource 354. 

ated with archive 210. It should be appreciated that in Referring next to Fig. 3c, the structure of an access 

other embodiments, archive 210 may not include a data fQe will be described in accordance with an embodiment 

block. of the present invention. Access file 360 generally 

Referring next to Fig. 3a, an embodiment of a di* 25 includes a table 361 which assodates prindpals 362 

ent-side directory structure will be described in accord- with permissions 364. Principals 362 may be individual 

ance with the present invention. A user who makes a hosts or groups of hosts. By way of example, "java.com" 

request to access a resource through a client generally may be an individual host, i.e., a server, which is a prin- 

interfaces with a user directory 302. User directory 302 dpal 362. Alternatively, "java.com" and "sun.com" may 

has an associated browser directory 304 which con- 30 form a principal 362 that is a group. In some embodi- 

tains information relating to a browser, or a user agent. ments, principals 362 can also be the signers of parte- 

The browser may be any suitable browser, as for exam- ular archives. Permissions 364 provide groupings of 

pie the Hotlava™ browser as mentioned above. security descriptors. That is. permissions 364 are 

Browser directory 304 includes a properties file 306 that groupings of security descriptors which designate the 

is appropriate to the request made by the user. Proper- 35 resources that principals 362, with which permissions 

ties file 306 typically indudes user preference items 308 364 are assodated. have access, 

which are generally browser specifications that are pro- Fig. 3d is a diagrammatic representation of a group 

vided by the user. These specifications may include, but specification ("spec") file format in accordance with an 

are not limited to, data relating to browser set-up and embodiment of the present invention. As mentioned 

behavioral properties associated with the browser. 40 above, the group specification file name 314 of Fig. 3a 

Properties file 306 further indudes information that identifies a group specification file, as for example group 
is relevant to the particular request made by the user. specification file 370. Group specification file 370 
By way of example, such information can include an includes a table 371 that assodates group names 372 
images data block 310, a configuration file name 312. with any number of members 374. Group names 372 
and a group specification file name 31 4. In one embod- 45 are essentially identifiers that may be used to identify a 
iment. images data block 310 includes data file names. group of member 374. By way of example, a group 
i.e.. strings, which identify any images that are associ- name, as for example group "1" 372a. may be assod- 
ated with the request. A configuration file name 312 is a ated with any number of members, as tor example 
string that identifies a configuration file which is used to member *r 374a and member "2" 374b. It should be 
facilitate the mapping of a requested resource to asso- so appreciated that a member, as for example member "1 " 
dated security descriptors. One example of a configura- 374a. may be associated with more than one group 
tion file will be described below with reference to Fig. 3b. name 372. 

Group specification ("spec") file name 314 is a string Fig. 4 is a process flow diagram which illustrates a 

which identifies a group specification file, as will be method of executing a request to access a resource in 

described below with respect to Fig. 3c. ss accordance with an embodiment of the present rnven- 

Fig. 3b rs a diagrammatic representation of the tion. The process begins at 402 and in a step 404, a call 

structure of a configuration file in accordance with an is made from a requesting client, e.g., client 74 of Fig. 

embodiment of the present invention. Configuration file lb, to a server, e.g., server 60 of Fig. 1b, to initiate the 
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download of either at least one class file, as described 
above with respect to Fig. 2a, or an archive file, as 
,l described above with respect to Fig. 2b. The request is 
received on the server in response to a client call made 
through a user agent, i.e., a browser, as for example a 
HotJava™ browser or a Netscape Navigator browser as 
previously mentioned. The initiation of the downloading 
of either at least one class file or an archive file occurs 
in response to a request to access a resource and, 
hence, is a call to execute an applet. In one preferred 
embodiment, the archive file is a JAR file. 

In a step 406, either the archive file is loaded or the 
class files are loaded from the server into memory asso- 
ciated with the requesting client. In general, class files 
are loaded if the classes are not in an archive file, e.g., 
not digitally signed, and an archive file is loaded if the 
classes are digitally signed. It should be appreciated 
that the archive file has associated class files. As such, 
loading the archive file involves loading class files. After 
the class files are loaded into memory, a validation proc- 
ess is performed on the loaded files in a step 408. The 
validation process, which includes the process of verify- 
ing whether the header signature associated with a 
loaded archive file is valid, in the event that an archive 
file has been loaded, will be described below with refer- 
ence to Fig. 5. 

After the validation process, in a step 410, the class 
files are converted into an applet. That is. an applet is 
created in memory by instantiating the loaded class 
files, which may or may not be a part of a JAR file. Once 
the applet is created, the applet file is executed in a step 
412. The steps associated with the execution of an 
applet will be described below with respect to Fig. 6. 

Fig. 5 is a process flow diagram which illustrates the 
steps associated with validating class files, /.e.. step 
408 of Fig. 4, in accordance with an embodiment of the 
present invention. The process begins at step 502, and 
in a step 504, a determination is made regarding 
whether an archive file or a class file has been loaded. 
If a class file has been loaded, then process flow pro- 
ceeds to a step 506 in which a standard class verifica- 
tion is performed. A standard class verification typically 
includes a check of all loaded class files and, therefore, 
classes, in order to ascertain whether anything in the 
class files may compromise security. In some embodi- 
ments, a check is made to determine if the security of a 
virtual machine, as for example a Java™ virtual 
machine, can be compromised. Standard class verifica- 
tion methods are generally well known to those of ordi- 
nary skill in the art. Once the standard class verification 
is performed, the process of validating the class files is 
completed at 520. 

If the determination in step 504 is that an archive 
file has been loaded, then in a step 508, the header of 
the archive file is validated, or authenticated. The vali- 
dation of the archive file generally involves an identifica- 
tion of the origin of the archive file based upon the 
header signature. That is, a check is made to establish 



the origin of the header signature and, therefore, the 
archive file. The validation may also include a check of 
whether data associated with the archive file is intact. It 
should be appreciated that in some embodiments, an 
5 archive file may not include a header signature. By way 
of example, an archive file within an intranet may not be 
signed. In a step 510. a determination is made as to 
whether the header is valid. If the header is not valid, 
e.g., the content of the archive does not correspond 
to with the signature, then in a step 514, an error flag or 
the like is raised. In one embodiment, the error flag may 
result in an exception being thrown. In another embodi- 
ment, the error flag may result in a message being 
returned to the requesting client. After the error flag is 
75 raised, the process of validating class files ends at 520. 
If the header is found to be valid in step 510. proc- 
ess flow moves from step 510 to a step 512 which is the 
determination of whether any classes associated with 
the archive file remain to be validated. If there is a class 
20 to be validated, then in a step 516. a standard class ver- 
ification is performed. As previously described in step 
506. a standard class verification includes a check of 
whether anything in a given class may compromise the 
security of a virtual machine. By way of example, the 
25 security of a virtual machine may be compromised if 
something in a given class can overwrite files or mem- 
ory on the virtual machine. After the standard class ver- 
ification is completed on the given class, process 
control returns to step 512 in which a determination is 
30 made regarding whether there are any more classes 
which are to be validated. Process control loops 
between steps 512 and 516 until a determination is 
made in step 51 2 that no more classes remain to be val- 
idated, at which point the process of validating class 
35 files is completed at 520. 

Fig . 6 is a process flow diagram which illustrates the 
steps associated with executing an applet in accord- 
ance with an embodiment of the present invention. That 
is, step 412 of Fig. 4 will be described. The process 
40 begins at 602, and. in a step 604, a determination is 
made as to whether the applet contains an instruction to 
execute an operation. The operation may generally be a 
call to access a system-level resource, tf the applet 
does not contain an instruction to execute an operation, 
4$ then the process of executing the applet ends at 616. If 
the applet does contain an instruction to execute an 
operation, then process flow proceeds to a step 606 in 
which it is determined whether the operation to be exe- 
cuted is a protected, e.g., secured, operation. That is, a 
so determination is made regarding whether the operation 
is an operation to which access is controlled. If it is 
determined that the operation is not protected, then the 
operation is executed in a step 608. and process flow 
returns to step 604, which is the determination of 
55 whether there is an instruction to execute another oper- 
ation. 

If it is determined in step 606 that the operation in 
the instruction to execute is protected, then process flow 
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moves to a step 610 in which the applet security man- 
ager is called. The process ot calling the security man- 
ager, will be described in more detail below with 
reference to Fig. 7. The applet security manager typi- 
cally controls the operations which are accessible to 
given applets. In one embodiment, the applet security 
manager is a Java™ applet security manager. In a step 
612, it is determined whether the operation is allowed. 
In other words, step 612 is the determination of whether 
the applet has access to the operation which is to be 
executed. If the operation is allowed, then the operation 
is executed in step 608. From step 608. process control 
returns to step 604 which is the determination of 
whether there is an instruction to execute another oper- 
ation. 

If the determination in step 61 2 is that the operation 
is not allowed, then an error condition occurs, which can 
be implemented by having an exception is thrown in 
step 614, and the process of executing the applet ends 
at 616. It should be appreciated that in some embodi- 
ments, the step of throwing an exception may involve 
calling a throw function. In other embodiments, the step 
of throwing an exception may involve transmitting an 
error message which may be displayed by a user agent 
that is associated with the requesting client. In still other 
embodiments, the error handling may cause an interac- 
tion with the user to occur in the form of asking whether 
the user approves the performance of the operation by 
the applet. In such embodiments, access files can pos- 
sibly be updated to permanently record the response 
provided by the user. 

Referring next to Fig. 7, the process of calling a 
security manager, he., step 610 of Fig. 6, will be 
described. It should be appreciated that a user agent 
generally has only one associated security manager. 
The process of calling a security manager begins at 702 
and in a step 704. the operation which is being called by 
the applet is identified. Although the operation may be 
any one of a number of operations, the operation is gen- 
erally a read operation or a write operation. Rom step 
704, process flow proceeds to a step 706 in which the 
name of the resource associated with the operation is 
identified. In some embodiments, the name of the 
resource is passed into the call to the security manager 
and. hence, is readily identified. However, when the 
name of the resource is not passed into the call, the 
properties file, as previously described with respect to 
Fig. 3a, may be used to identify the associated 
resource. 

Once the associated resource is identified in step 
706, the name of the access file which corresponds to 
the resource is identified using the configuration file, 
which was described earlier with respect to Fig. 3b, that 
is associated with the applet. Permissions correspond- 
ing to the applet are then obtained from the access file 
in a step 710. It should be appreciated that in some 
embodiments, the appropriate access file may be a rep- 
resentation of the actual access file in memory. The 



access file, as described above with respect to Fig. 3c, 
associates individual hosts or groups with a set of per- 
missions. After the permissions are obtained, the call to 
the security manager is completed at 712. 
5 Fig. 8 illustrates a typical computer system in 
accordance with the present invention. The computer 
system 830 includes any number of processors 832 
(also referred to as central processing units, or CPUs) 
that is coupled to memory devices inducing primary 
10 storage devices 834 (typically a read only memory, or 
ROM) and primary storage devices 836 (typically a ran- 
dom access memory, or RAM). As is well known in the 
art, ROM 834 acts to transfer data and instructions uni- 
directionally to the CPU and RAM 836 is used typically 
75 to transfer data and instructions in a bi-directional man- 
ner. Both primary storage devices 834, 836 may include 
any suitable computer-readable media as descrbed 
above. A mass memory device 838 is also coupled bi- 
directionally to CPU 832 and provides additional data 
20 storage capacity. The mass memory device 838 may be 
used to store programs, data and the like and is typically 
a secondary storage medium such as a hard disk that is 
slower than primary storage devices 834, 836. Mass 
memory storage device 838 may take the form of a 
25 magnetic or paper tape reader or some other well- 
known device. It will be appreciated that the information 
retained within the mass memory device 838, may, in 
appropriate cases, be incorporated in standard fashion 
as part of RAM 836 as virtual memory. A specific mass 
30 storage device such as a CD-ROM 834 may also pass 
data uni-directionally to the CPU. 

CPU 832 is also coupled to one or more input/out- 
put devices 840 that may include, but are not limited to, 
devices such as video monitors, track balls, mice, key- 
as boards, microphones, touch-sensitive displays, trans- 
ducer card readers, magnetic or paper tape readers, 
tablets, styluses, voice or handwriting recognizers, or 
other well-known input devices such as, of course, other 
computers. Finally, CPU 832 optionally may be coupled 
40 to a computer or telecommunications network, e.g. . an 
Internet network or an intranet network, using a network 
connection as shown generally at 812. With such a net- 
work connection, it is contemplated that the CPU might 
receive information from the network, or might output 
45 information to the network in the course of performing 
the above-described method steps. The above- 
described devices and materials will be familiar to those 
of skill in the computer hardware and software arts. Fur- 
ther, it should be appreciated by those skilled in the art 
so that the above described hardware and software ele- 
ments, as well as networking devices, are of standard 
design and construction. 

The computer-implemented methods described 
herein can be implemented using techniques and appa- 
55 ratus that are well-known in the computer science arts 
for executing computer program instructions on compu- 
ter systems. As used herein, the term "computer sys- 
tem" is defined to include a processing device (such as 
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a central processing unit. CPU) lor processing data and 
instructions that is coupled with one or more data stor- 
" age devices for exchanging data and instructions with 
the processing unit, including, but not limited to, RAM, 
ROM, CD-ROM, hard disks, and the like. The data stor- 5 
age devices can be dedicated, i.e., coupled directly with 
the processing unit, or remote, /.e., coupled with the 
processing unit over a computer network. It should be 
appreciated that remote data storage devices coupled 
to a processing unit over a computer network can be to 
capable of sending program instructions to a processing 
unit for execution on a particular workstation. In addi- 
tion, the processing device can be coupled with one or 
more additional processing devices, either through the 
same physical structure {e.g., a parallel processor), or 15 
over a computer network (e.g., a distributed proces- 
sor.). The use of such remotely coupled data storage 
devices and processors will be familiar to those of skill in 
the computer science arts (see, e.g., Ralston 1993). 
The term "computer network" as used herein is defined 20 
to include a set of communications channels intercon- 
necting a set of computer systems that can communi- 
cate with each other The communications channels 
can include transmission media such as. but not limited 
to. twisted pair wires, coaxial cable, optical fibers, satel- 2 s 
lite links, or digital microwave radio. The computer sys- 
tems can be distributed over large, or "wide," areas 
(e.g., over tens, hundreds, or thousands of miles, 
WAN), or local area networks (e.g., over several feet to 
hundreds of feet, LAN). Furthermore, various local-area 30 
and wide-area networks can be combined to form 
aggregate networks of computer systems. One example 
of such a confederation of computer networks is the 
"Internet". 

Although only a few embodiments of the present 35 
invention have been described, it should be understood 
that the present invention may be embodied in many 
other specific forms without departing from the spirit or 
the scope of the present invention. By way of example, 
although only one configuration of an archive file data 40 
structure which may be signed has been described, it 
should be appreciated that the archive file data struc- 
ture may be widely varied within the scope of the 
present invention. Further, steps involved with a method 
of executing a request to access system resources may 45 
be reordered. Steps may also be removed or added 
without departing from the spirit or the scope of the 
present invention. Therefore the described embodi- 
ments should be taken as illustrative and not restrictive, 
and the invention should be defined by the following so 
claims and their full scope of equivalents. 

Claims 

1. A method for controlling the degree of access to 55 
operating system resources for a software program 
running on a computer which computer is running 
said operating system, the method comprising the 



steps of: 

(a) defining said degree of access to said oper- 
ating system resources for said software pro- 
gram; 

(b) examining at least one file associated with 
said software program to determine the degree 
of system-level access available to said soft- 
ware program when said software program is 
being executed by said computer; 

(c) executing said software program on said 
computer; 

(d) intercepting a program instruction associ- 
ated with said software program when said 
software program is being executed on said 
computer; 

(e) determining if said program instruction 
includes an operation that is outside said 
degree of system-level access available to said 
software program; and 

(f) executing said program instruction when it is 
determined that said software program has 
permission to access system-level resources 
associated with said computer that are within 
the degree of system-level access available to 
sad software program. 

2. A method as recited in claim 1 wherein said step of 
determining if said program instruction includes an 
operation that is outside said degree of system- 
level access available to said software program 
comprises validating an identifier associated with 
said software program. 

3. A method as recited in any one of the preceding 
claims wherein said step of executing said program 
instruction comprises determining if said system- 
level resources being accessed by said program 
instruction are protected system-level resources. 

4. A method as recited in any one of the preceding 
claims wherein said software program comprises 
an applet. 

5. A method as recited in claim 4 wherein said applet 
is a Java applet. 

6. A method as recited in one of claims 4 and 5 
wherein said applet is associated with a header, 
said header being arranged to include an identifier, 
said identifier being arranged to identify said an ori- 
gin of said file. 

7. A method as recited in claim 6 further including the 
step of validating said identifier to determine if said 
computer has permission to access said system- 
level resources. 
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8. A method as recited in one of claims 4-7 wherein 
said computer is a client computer and said applet 

' is downloaded to said client computer from a server 
computer. 

5 

9. A method as recited in claim 8 wherein: 

(a) said step of examining includes determining 
the degree of system-level access to said 
server that is available to said applet when said w 
applet is being executed by said client compu- 
ter as defined by said defining a degree of 
access to said system-level resources associ- 
ated with said server computer for said applet; 

(b) said step of determining includes determin- is 
ing if said program instruction to access sys- 
tem-level resources associated with said 
server computer includes an operation that is 
outside said degree of system-level access 
available to said applet; and 20 

(c) said step of executing includes executing 
said program instruction to access system- 
level resources associated with said server 
computer when it is determined that said applet 
has permission to access system-level 25 
resources associated with said server compu- 
ter that are within the degree of system-level 
access available to said applet. 

10. A method for controlling the degree of access to 30 
operating system resources for a software program 
running oh a client computer which client computer 
is running said operating system, wherein at least 
some of said operating system resources reside on 
a server computer that ts coupled with said client 35 
computer through a computer network the method 
comprising the steps of: 

(a) defining said degree of access to said oper- 
ating system resources for said software pro- 40 
gram; 

(b) loading at least one file including instruc- 
tions for executing said software program on 
said client computer ; 

(c) examining said at least one file to determine 4S 
the degree of system-level access available to 
said software program when said software pro- 
gram is being executed by said client computer 
as defined by said step of defining said degree 
ol access; so 

(d) executing said software program on said cli- 
ent computer; 

(e) intercepting a program instruction associ- 
ated with said software program when said 
software program is being executed on said di- ss 
ent computer; 

(f) determining if said program instruction 
includes an operation that is outside said 



degree of system-level access available to said 
software program; and 

(g) executing said program instruction when it 
is determined that said software program has 
permission to access system-level resources 
that are within the degree of system-level 
access available to said software program. 

11. A method as recited in claim 10 wherein said step 
of determining rf said program instruction includes 
an operation that is outside said degree of system- 
level access available to said software program 
comprises validating an identifier associated with 
said software program. 

12. A method as recited in one of claims 10 and 11 
wherein said step of executing said program 
instruction comprises determining if said system- 
level resources being accessed by said program 
instruction are protected system-level resources. 

13. A method as recited in one of claim 10-12 further 
including the steps of: 

establishing a data transfer communication link 
between said dient computer and said server 
computer across said computer network; and 
transmitting said at least one file from said 
server computer to said dient computer across 
said computer network. 

14. A method for processing a request from a client to 
access a system resource associated with a first 
server, the method comprising the steps of: 

(a) calling a second server to initiate a down- 
load of files that are relevant to said request; 

(b) loading said relevant files from said second 
server, said relevant files induding an archive 
file, said archive file including at least one dass 
file and a header, said header including an 
identifier arranged to indicate the origin of said 
archive file; 

(c) validating said archive file; 

(d) converting said class f ile into an applet; and 

(e) executing said applet said applet induding 
at least one instruction, wherein executing said 
applet enables said client to access said sys- 
tem resource associated with said first server. 

15. A method for processing a request as redted in 
daim 1 4 wherein said step of validating said archive 
file includes the sub-steps of: 

(a) authenticating said header ; 

(b) determining whether said header is valid; 
and 

(c) performing a class verification on said dass 
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when it is determined that said header is valid. 

* 16. A method for processing a request as recited in one 
* of claims 14 and 15 wherein said step of executing 
said applet includes the sub-steps of : 

(a) determining whether said instruction is an 
instruction to execute a protected operation; 

(b) executing said operation when it is deter- 
mined that said instruction is not an instruction 
to execute a protected operation; and 

(c) determining whether said operation is 
allowed when it is determined that said instruc- 
tion is an instruction to execute a protected 
operation. 

17. A computer system for controlling the degree of 
access to operating system resources comprising: 

a first computer coupled with at least one mem- 
ory device which holds therein at least one file 
including instructions for executing a software 
program, said software program running on 
said first computer, said first computer running 
said operating system, said first computer 
being configured to: 

(a) define said degree of access to said 
operating system resources tor said soft- 
ware program and said first computer 
being configured determine if a program 
instruction associated with said software; 

(b) toad said at least one file including 
instructions tor executing said software 
program on said first computer; 

(c) examine said at least one file to deter- 
mine the degree of system-level access 
available to said software program when 
said software program is being executed 
by said first computer; 

(d) execute said software program on said 
first computer; 

(e) intercept a program instruction associ- 
ated with said software program when said 
software program is being executed on 
said first computer; 

(f) determine if said program instruction 
includes an operation that is outside said 
degree of system-level access available to 
said software program; and 

(g) execute said program instruction when 
it is determined that said software program 
has permission to access system-level 
resources associated with said first com- 
puter that are within the degree of system- 
level access available to said software pro- 
gram. 



18. A computer system according to claim 17 wherein 
said first computer is arranged to determine if said 
system-level resources being accessed by said 
program instruction are protected system-level 

5 resources. 

19. A computer-readable medium comprising compu- 
ter-readable program code devices configured to 
cause a computer to perform the actions of: 

TO 

(a) def ining said degree of access to said oper- 
ating system resources tor said software pro- 
gram; 

(b) examining at least one file associated with 
is said software program to determine the degree 

of system-level access available to said soft- 
ware program when said software program is 
being executed by said computer; 

(c) executing said software program on said 
20 computer; 

(d) intercepting a program instruction associ- 
ated with said software program when said 
software program is being executed on said 
computer; 

2$ (e) determining if said program instruction 

includes an operation that is outside said 
degree of system-level access available to said 
software program; and . 
(f) executing said program instruction when *rt is 

30 determined that said software program has 

permission to access system-level resources 
associated with said computer that are within 
the degree of system-level access available to 
said software program. 
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